ap2(ap2(map, f), xs) -> ap2(ap2(ap2(if, ap2(isEmpty, xs)), f), xs)
ap2(ap2(ap2(if, true), f), xs) -> null
ap2(ap2(ap2(if, null), f), xs) -> ap2(ap2(cons, ap2(f, ap2(last, xs))), ap2(ap2(if2, f), xs))
ap2(ap2(if2, f), xs) -> ap2(ap2(map, f), ap2(dropLast, xs))
ap2(isEmpty, null) -> true
ap2(isEmpty, ap2(ap2(cons, x), xs)) -> null
ap2(last, ap2(ap2(cons, x), null)) -> x
ap2(last, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(last, ap2(ap2(cons, y), ys))
ap2(dropLast, ap2(ap2(cons, x), null)) -> null
ap2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(ap2(cons, x), ap2(dropLast, ap2(ap2(cons, y), ys)))
↳ QTRS
↳ DependencyPairsProof
ap2(ap2(map, f), xs) -> ap2(ap2(ap2(if, ap2(isEmpty, xs)), f), xs)
ap2(ap2(ap2(if, true), f), xs) -> null
ap2(ap2(ap2(if, null), f), xs) -> ap2(ap2(cons, ap2(f, ap2(last, xs))), ap2(ap2(if2, f), xs))
ap2(ap2(if2, f), xs) -> ap2(ap2(map, f), ap2(dropLast, xs))
ap2(isEmpty, null) -> true
ap2(isEmpty, ap2(ap2(cons, x), xs)) -> null
ap2(last, ap2(ap2(cons, x), null)) -> x
ap2(last, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(last, ap2(ap2(cons, y), ys))
ap2(dropLast, ap2(ap2(cons, x), null)) -> null
ap2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(ap2(cons, x), ap2(dropLast, ap2(ap2(cons, y), ys)))
AP2(ap2(map, f), xs) -> AP2(ap2(if, ap2(isEmpty, xs)), f)
AP2(ap2(ap2(if, null), f), xs) -> AP2(f, ap2(last, xs))
AP2(ap2(ap2(if, null), f), xs) -> AP2(ap2(if2, f), xs)
AP2(ap2(map, f), xs) -> AP2(if, ap2(isEmpty, xs))
AP2(ap2(ap2(if, null), f), xs) -> AP2(cons, ap2(f, ap2(last, xs)))
AP2(ap2(ap2(if, null), f), xs) -> AP2(ap2(cons, ap2(f, ap2(last, xs))), ap2(ap2(if2, f), xs))
AP2(ap2(map, f), xs) -> AP2(isEmpty, xs)
AP2(last, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> AP2(last, ap2(ap2(cons, y), ys))
AP2(ap2(ap2(if, null), f), xs) -> AP2(last, xs)
AP2(ap2(if2, f), xs) -> AP2(dropLast, xs)
AP2(ap2(ap2(if, null), f), xs) -> AP2(if2, f)
AP2(ap2(map, f), xs) -> AP2(ap2(ap2(if, ap2(isEmpty, xs)), f), xs)
AP2(ap2(if2, f), xs) -> AP2(ap2(map, f), ap2(dropLast, xs))
AP2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> AP2(dropLast, ap2(ap2(cons, y), ys))
AP2(ap2(if2, f), xs) -> AP2(map, f)
AP2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> AP2(ap2(cons, x), ap2(dropLast, ap2(ap2(cons, y), ys)))
ap2(ap2(map, f), xs) -> ap2(ap2(ap2(if, ap2(isEmpty, xs)), f), xs)
ap2(ap2(ap2(if, true), f), xs) -> null
ap2(ap2(ap2(if, null), f), xs) -> ap2(ap2(cons, ap2(f, ap2(last, xs))), ap2(ap2(if2, f), xs))
ap2(ap2(if2, f), xs) -> ap2(ap2(map, f), ap2(dropLast, xs))
ap2(isEmpty, null) -> true
ap2(isEmpty, ap2(ap2(cons, x), xs)) -> null
ap2(last, ap2(ap2(cons, x), null)) -> x
ap2(last, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(last, ap2(ap2(cons, y), ys))
ap2(dropLast, ap2(ap2(cons, x), null)) -> null
ap2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(ap2(cons, x), ap2(dropLast, ap2(ap2(cons, y), ys)))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
AP2(ap2(map, f), xs) -> AP2(ap2(if, ap2(isEmpty, xs)), f)
AP2(ap2(ap2(if, null), f), xs) -> AP2(f, ap2(last, xs))
AP2(ap2(ap2(if, null), f), xs) -> AP2(ap2(if2, f), xs)
AP2(ap2(map, f), xs) -> AP2(if, ap2(isEmpty, xs))
AP2(ap2(ap2(if, null), f), xs) -> AP2(cons, ap2(f, ap2(last, xs)))
AP2(ap2(ap2(if, null), f), xs) -> AP2(ap2(cons, ap2(f, ap2(last, xs))), ap2(ap2(if2, f), xs))
AP2(ap2(map, f), xs) -> AP2(isEmpty, xs)
AP2(last, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> AP2(last, ap2(ap2(cons, y), ys))
AP2(ap2(ap2(if, null), f), xs) -> AP2(last, xs)
AP2(ap2(if2, f), xs) -> AP2(dropLast, xs)
AP2(ap2(ap2(if, null), f), xs) -> AP2(if2, f)
AP2(ap2(map, f), xs) -> AP2(ap2(ap2(if, ap2(isEmpty, xs)), f), xs)
AP2(ap2(if2, f), xs) -> AP2(ap2(map, f), ap2(dropLast, xs))
AP2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> AP2(dropLast, ap2(ap2(cons, y), ys))
AP2(ap2(if2, f), xs) -> AP2(map, f)
AP2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> AP2(ap2(cons, x), ap2(dropLast, ap2(ap2(cons, y), ys)))
ap2(ap2(map, f), xs) -> ap2(ap2(ap2(if, ap2(isEmpty, xs)), f), xs)
ap2(ap2(ap2(if, true), f), xs) -> null
ap2(ap2(ap2(if, null), f), xs) -> ap2(ap2(cons, ap2(f, ap2(last, xs))), ap2(ap2(if2, f), xs))
ap2(ap2(if2, f), xs) -> ap2(ap2(map, f), ap2(dropLast, xs))
ap2(isEmpty, null) -> true
ap2(isEmpty, ap2(ap2(cons, x), xs)) -> null
ap2(last, ap2(ap2(cons, x), null)) -> x
ap2(last, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(last, ap2(ap2(cons, y), ys))
ap2(dropLast, ap2(ap2(cons, x), null)) -> null
ap2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(ap2(cons, x), ap2(dropLast, ap2(ap2(cons, y), ys)))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ QDP
AP2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> AP2(dropLast, ap2(ap2(cons, y), ys))
ap2(ap2(map, f), xs) -> ap2(ap2(ap2(if, ap2(isEmpty, xs)), f), xs)
ap2(ap2(ap2(if, true), f), xs) -> null
ap2(ap2(ap2(if, null), f), xs) -> ap2(ap2(cons, ap2(f, ap2(last, xs))), ap2(ap2(if2, f), xs))
ap2(ap2(if2, f), xs) -> ap2(ap2(map, f), ap2(dropLast, xs))
ap2(isEmpty, null) -> true
ap2(isEmpty, ap2(ap2(cons, x), xs)) -> null
ap2(last, ap2(ap2(cons, x), null)) -> x
ap2(last, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(last, ap2(ap2(cons, y), ys))
ap2(dropLast, ap2(ap2(cons, x), null)) -> null
ap2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(ap2(cons, x), ap2(dropLast, ap2(ap2(cons, y), ys)))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
AP2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> AP2(dropLast, ap2(ap2(cons, y), ys))
POL(AP2(x1, x2)) = 2·x1·x2
POL(ap2(x1, x2)) = 2·x1 + 2·x1·x2
POL(cons) = 2
POL(dropLast) = 2
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
↳ QDP
↳ QDP
ap2(ap2(map, f), xs) -> ap2(ap2(ap2(if, ap2(isEmpty, xs)), f), xs)
ap2(ap2(ap2(if, true), f), xs) -> null
ap2(ap2(ap2(if, null), f), xs) -> ap2(ap2(cons, ap2(f, ap2(last, xs))), ap2(ap2(if2, f), xs))
ap2(ap2(if2, f), xs) -> ap2(ap2(map, f), ap2(dropLast, xs))
ap2(isEmpty, null) -> true
ap2(isEmpty, ap2(ap2(cons, x), xs)) -> null
ap2(last, ap2(ap2(cons, x), null)) -> x
ap2(last, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(last, ap2(ap2(cons, y), ys))
ap2(dropLast, ap2(ap2(cons, x), null)) -> null
ap2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(ap2(cons, x), ap2(dropLast, ap2(ap2(cons, y), ys)))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
AP2(last, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> AP2(last, ap2(ap2(cons, y), ys))
ap2(ap2(map, f), xs) -> ap2(ap2(ap2(if, ap2(isEmpty, xs)), f), xs)
ap2(ap2(ap2(if, true), f), xs) -> null
ap2(ap2(ap2(if, null), f), xs) -> ap2(ap2(cons, ap2(f, ap2(last, xs))), ap2(ap2(if2, f), xs))
ap2(ap2(if2, f), xs) -> ap2(ap2(map, f), ap2(dropLast, xs))
ap2(isEmpty, null) -> true
ap2(isEmpty, ap2(ap2(cons, x), xs)) -> null
ap2(last, ap2(ap2(cons, x), null)) -> x
ap2(last, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(last, ap2(ap2(cons, y), ys))
ap2(dropLast, ap2(ap2(cons, x), null)) -> null
ap2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(ap2(cons, x), ap2(dropLast, ap2(ap2(cons, y), ys)))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
AP2(last, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> AP2(last, ap2(ap2(cons, y), ys))
POL(AP2(x1, x2)) = 2·x1·x2
POL(ap2(x1, x2)) = 2·x1 + 2·x1·x2
POL(cons) = 2
POL(last) = 2
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
↳ QDP
ap2(ap2(map, f), xs) -> ap2(ap2(ap2(if, ap2(isEmpty, xs)), f), xs)
ap2(ap2(ap2(if, true), f), xs) -> null
ap2(ap2(ap2(if, null), f), xs) -> ap2(ap2(cons, ap2(f, ap2(last, xs))), ap2(ap2(if2, f), xs))
ap2(ap2(if2, f), xs) -> ap2(ap2(map, f), ap2(dropLast, xs))
ap2(isEmpty, null) -> true
ap2(isEmpty, ap2(ap2(cons, x), xs)) -> null
ap2(last, ap2(ap2(cons, x), null)) -> x
ap2(last, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(last, ap2(ap2(cons, y), ys))
ap2(dropLast, ap2(ap2(cons, x), null)) -> null
ap2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(ap2(cons, x), ap2(dropLast, ap2(ap2(cons, y), ys)))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDPOrderProof
AP2(ap2(ap2(if, null), f), xs) -> AP2(f, ap2(last, xs))
AP2(ap2(map, f), xs) -> AP2(ap2(ap2(if, ap2(isEmpty, xs)), f), xs)
AP2(ap2(ap2(if, null), f), xs) -> AP2(ap2(if2, f), xs)
AP2(ap2(if2, f), xs) -> AP2(ap2(map, f), ap2(dropLast, xs))
ap2(ap2(map, f), xs) -> ap2(ap2(ap2(if, ap2(isEmpty, xs)), f), xs)
ap2(ap2(ap2(if, true), f), xs) -> null
ap2(ap2(ap2(if, null), f), xs) -> ap2(ap2(cons, ap2(f, ap2(last, xs))), ap2(ap2(if2, f), xs))
ap2(ap2(if2, f), xs) -> ap2(ap2(map, f), ap2(dropLast, xs))
ap2(isEmpty, null) -> true
ap2(isEmpty, ap2(ap2(cons, x), xs)) -> null
ap2(last, ap2(ap2(cons, x), null)) -> x
ap2(last, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(last, ap2(ap2(cons, y), ys))
ap2(dropLast, ap2(ap2(cons, x), null)) -> null
ap2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(ap2(cons, x), ap2(dropLast, ap2(ap2(cons, y), ys)))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
AP2(ap2(ap2(if, null), f), xs) -> AP2(f, ap2(last, xs))
Used ordering: Polynomial interpretation [21]:
AP2(ap2(map, f), xs) -> AP2(ap2(ap2(if, ap2(isEmpty, xs)), f), xs)
AP2(ap2(ap2(if, null), f), xs) -> AP2(ap2(if2, f), xs)
AP2(ap2(if2, f), xs) -> AP2(ap2(map, f), ap2(dropLast, xs))
POL(AP2(x1, x2)) = x1
POL(ap2(x1, x2)) = 1 + x2
POL(cons) = 0
POL(dropLast) = 0
POL(if) = 0
POL(if2) = 0
POL(isEmpty) = 0
POL(last) = 0
POL(map) = 0
POL(null) = 0
POL(true) = 0
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
AP2(ap2(map, f), xs) -> AP2(ap2(ap2(if, ap2(isEmpty, xs)), f), xs)
AP2(ap2(ap2(if, null), f), xs) -> AP2(ap2(if2, f), xs)
AP2(ap2(if2, f), xs) -> AP2(ap2(map, f), ap2(dropLast, xs))
ap2(ap2(map, f), xs) -> ap2(ap2(ap2(if, ap2(isEmpty, xs)), f), xs)
ap2(ap2(ap2(if, true), f), xs) -> null
ap2(ap2(ap2(if, null), f), xs) -> ap2(ap2(cons, ap2(f, ap2(last, xs))), ap2(ap2(if2, f), xs))
ap2(ap2(if2, f), xs) -> ap2(ap2(map, f), ap2(dropLast, xs))
ap2(isEmpty, null) -> true
ap2(isEmpty, ap2(ap2(cons, x), xs)) -> null
ap2(last, ap2(ap2(cons, x), null)) -> x
ap2(last, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(last, ap2(ap2(cons, y), ys))
ap2(dropLast, ap2(ap2(cons, x), null)) -> null
ap2(dropLast, ap2(ap2(cons, x), ap2(ap2(cons, y), ys))) -> ap2(ap2(cons, x), ap2(dropLast, ap2(ap2(cons, y), ys)))